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DETAILED ACTION 

This Office Action is in response to a communication made on April 24, 2004. 
Claims 1-63 are pending in this application. 

Response to Amendment 
Claim Rejections - 35 USC § 102 
The following is a quotation of the appropriate paragraphs of 35 U.S.C. 102 that 
form the basis for the rejections under this section made in this Office action: 
A person shall be entitled to a patent unless - 

(b) the invention was patented or described in a printed publication in this or a foreign country or in public 
use or on sale in this country, more than one year prior to the date of application for patent in the United 
States. 

Claims 1-45 and 47-63 are rejected under 35 U.S.C. 102(b) as being 
anticipated by Leblang (5649200). 

Regarding claim 1, Leblang discloses a computer- readable medium having 
computer-executable instructions comprising: querying a first server for a location of a 
second server (Column 5, lines 45 - 53; Column 8, lines 31 - 35), the second server 
comprising update information associated with an executable (Column 6, lines 4-19); 
linking the first server to the second server (Column 8, lines 31 - 35) ; querying the 
second server for the update information (Column 1 1 , lines 53 - 64); receiving the 
update information from the second server (Column 9, lines 41 - 45: Column 12, lines 8 
- 17), and updating software associated with the executable based on the update 
information (Column 9, lines 41 -45) . 
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Regarding claim 2, Leblang discloses that querying a first server further 
comprises providing a path to a look up HyperText Transfer Protocol (HTTP) symbol 
location server (Column 8, lines 43 - 51 ). 

Regarding claim 3, Leblang discloses that querying a first server further 
comprises querying a Dynamic Host Configuration Protocol (DHCP) server and 
requesting Uniform Resource Identifiers (URIs) to query the second server for the 
update information (Column 6, lines 1-19). 

Regarding claim 4, Leblang discloses that querying a first server further 
comprises querying a Domain Name System (DNS) server for a service (SRV) record 
identifying the second server to be queried (Column 8, lines 43 - 51). 

Regarding claim 5, Leblang discloses that querying a first server further 
comprises querying a directory service for the location of the second server (Column 6, 
lines 51 -61). 

Regarding claim 6, Leblang discloses that querying a first server further 
comprises querying an Application Configuration, Access Protocol (ACAP) server for 
the location of the second server (Column 12, lines 56 - 67). 

Regarding claim 7, Leblang discloses that querying a first server further 
comprises querying a Lightweight Directory Access Protocol (LDAP) server for the 
location of the second server (Column 8, lines 30 - 35; Column 1 1 , lines 61 - 64). 

Regarding claim 8, Leblang discloses a computer-readable medium having 
computer-executable instructions comprising: creating a path to a symbol location 
server without registering the oath in an environment variable (Column 14. lines 25 - 
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39) : querying the symbol location server through the path for symbols associated with a 
local file wherein the path is created based on the type of symbols (Column 16. lines 31 
-44; lines 62-67) : receiving the symbols from symbol location server through the 
path: and updating software associated with the local file based on the received 
symbols (Column 18, lines 25 - 32) . 

Regarding claim 9, Leblang discloses that querying the symbol location server 
further comprises querying the symbol location server with a unique identifier composed 
of different values from an image header extracted from the local file (Column 15, lines 
47 - 51 ; Column 1 0, line 65 - Column 1 1 , line 3). 

Regarding claim 10, Leblang discloses that the unique identifier composed of 
different values from an image header includes values, which are not replicated 
between differing versions of the local file (Column 9, lines 47 - 57). 

Regarding claim 11, Leblang discloses that receiving the symbols further 
comprises receiving a file comprising the symbols, wherein the file is stored in a local 
system memory (Column 13, line 65 - Column 14, line 7). 

Regarding claim 12, Leblang discloses that querying the symbol location server 
for further comprises querying the symbol location server with a user customized query 
which extracts over a back end store (Column 16, lines 40 - 44). 

Regarding claim 13, Leblang discloses a computer-readable medium having 
computer-executable instructions comprising: creating a path to a first server 
comprising location information for a second server comprising update information 
associated with an executable without registering the path with an environment variable 
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(Column 14. lines 25 - 39: Column 2. line 2): querying the first server through the path 
for the update information (Column 2, lines 6- 14) : receiving the update information 
from the first server through the path : and updating software associated with the 
executable based on the update information (Column 2, lines 53-64: Column 11, lines 
53 - 60) . 

Regarding claim 14, Leblang discloses that receiving the update information 
further comprises receiving reference location on the second server which is used to 
access a file associated with the executable on the second server (Column 2, line 65 - 
Column 3, line 10). 

Regarding claim 15, Leblang discloses the idea of querying the first server further 
comprises querying a server selected from a group consisting of a DHCP server, a DNS 
server, an ACAP server, and a LDAP server (Column 3, lines 31 -40; Column 2, line 65 
- Column 3, line 1 ; Column 8, lines 43 - 51 ; Column 12, lines 56 - 67) where the type 
of connection and query and action the user takes, allows the system to take different 
action with the first server/ distributed system. 

Regarding claim 16, Leblang discloses that querying the first server further 
comprises querying a set of servers in parallel (Column 1 6, lines 6-9) where the script 
allows the search of may objects/files at once and it also allows different types of 
searching for those files such as certain version location or query into the metadata. 

Regarding claim 17, Shklar discloses that querying the first server further 
comprises querying a set of servers in a serial order (Column 2, lines 65 - Column 3, 
line 4; Column 16, lines 62 - 67) because in order to connect all the objects and locate 
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all related information to those objects the system needs to transverse all paths and 
types of location techniques in the system, such as first locating the object and the 
pathnames to that objects versions, then looking in the object directory for metadata 
leading to hyperlinks for other objects which are merged or related. 

Regarding claim 18, Leblang discloses that querying the first server further 
comprises packaging information extracted from the executable into a HyperText 
Transfer Protocol (HTTP) request and sending the HTTP request to first server (Column 
9. lines 47-61) . 

Regarding claim 19, Leblang discloses a computer-readable medium having 
computer-executable instructions comprising: querying a first server comprising location 
information for a second server comprising update information associated with an 
executable (Column 2, lines 53 - Column 3, line 9); receiving the location information 
from the first server; creating a path to the second server based on the type of update 
information without registering the path in an environment variable (Column 2, lines 53- 
Column 3, line 9; Column 16, lines 31 -44)); querying the second server through the 
path for the update information associated with the executable using a syntax based on 
the location information received for the second server (Column 16, lines 40 - 44; 
Column 1 6, line 62 - Column 1 7, line 5); and updating software associated with the 
executable based on the update information (Column 2, lines 53 - 64: Column 1 1 , lines 
53 - 60) . 
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Regarding claim 20, Leblang discloses that querying a first server further 
comprises querying the first server using metadata associated with the executable 
(Column 15, lines 46 - 50). 

Regarding claim 21 , Leblang discloses that querying the second server further 
comprises querying the second server using metadata associated with the executable 
(Column 1 6, lines 40 - 44; lines 63 - 67). 

Regarding claim 22, Leblang discloses that the metadata comprises metadata for 
a number of debug files (Column 1 7, lines 2-10). 

Regarding claim 23, Leblang discloses that the metadata comprises metadata for 
a number of source files (Column 2, lines 23 - 29). 

Regarding claim 24, Leblang discloses that querying the second server further 
comprises querying the second server for symbols associated with the executable file 
(Column 2, lines 65 - Column 3, line 4). 

Regarding claim 25, Leblang discloses that querying the second server further 
comprises querying the second server for regression analysis data associated with the 
executable file (Column 5, line 61 - Column 6, line 3). 

Regarding claim 26, Leblang discloses that querying the second server further 
comprises querying the second server for performance analysis data associated with 
the executable file (Column 5, line 61 - Column 6, line 3). 

Regarding claim 27, Leblang discloses that querying the second server further 
comprises querying the second server for source code associated with the executable 
file (Column 5, line 61 - Column 6, line 3). 
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Regarding claim 28, Leblang discloses that querying the second server further 
comprising receiving files comprising the update information associated with the 
executable file (Column 5, line 61 - Column 6, line 3). 

Regarding claim 29, Leblang discloses a computer-readable medium having 
computer-executable instructions for updating a software program associated with an 
executable file comprising: packaging metadata extracted from the executable file into 
an HTTP request (Column 2, lines 24 - 52); creating a path to a locator server without 
registering the path with an environment variable (Column 14, lines 25 - 39: Column 2, 
line 2), the locator server comprising information for a server on which update 
information associated with the executable is located (Column 2, line 65 - Column 3, 
line 4) : sending through the path the HTTP request to the locator servers; receiving the 
update information from the locator server through the path (Column 2, line 65 - 
Column 3, line 4) : and updating the software program associated with the executable 
file based on the update information (Column 2, lines 53 - 64: Column 1 1 . lines 53 - 
60). 

Regarding claim 30, Leblang discloses that packaging metadata further 
comprising packaging metadata to locate an updated version of the executable file 
(Column 11, lines 53-64). 

Regarding claim 31 , Leblang discloses that packaging metadata further 
comprises packaging metadata for locating a debug file associated with the executable 
file (Column 17, lines 2 - 10). 
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Regarding claim 32, Leblang discloses that packaging metadata further 
comprises packaging metadata to locate a specific build version of the executable file 
(Column 9, lines 39 - 57). 

Regarding claim 33, Leblang discloses that receiving the update information 
further comprises receiving an HTTP redirect (Column 2, line 65 - Column 3, line 1). 

Regarding claim 34, Leblang discloses that receiving the update information 
further comprises receiving a location of the server on which the update information is 
located, and querying the server with a unique identifier for the update information 
(Column 7, lines 54 - 61 ; Column 1 7, lines 22 - 29). 

Regarding claim 35, Leblang discloses that querying the server further comprises 
providing an additional qualifier (Column 1 5, lines 46 - 51 ). 

Regarding claim 36, Leblang discloses a computerized system, comprising: a 
first server comprising location information for update information associated with a 
local file (Column 2, lines 53 - 64: Column 1 1 . lines 53 - 60) : a second server 
comprising the update information, wherein the first server is linked to the second server 
though a path that is created based on the type of updated information without 
registering the path with an environment variable (Column 2, line 65 - Column 3, line 4), 
and further wherein the first server receives the update information from the second 
server though the path (Column 15, line 56 - Column 16, line 9) : and a computer 
comprising a local file, wherein the first server provides the update information to the 
computer such that software associated with the local file is updated based on the 
update information (Column 2, lines 53 - 64: Column 1 1 . lines 53 - 60) . 
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Regarding claim 37, Leblang discloses that the update information comprises 
debug information (Column 17. lines 2-10). 

Regarding claim 38, Leblang discloses that the update information comprises 
solution access information (Column 5, line 61 - Column 6, line 5) . 

Regarding claim 39, Leblang discloses that the computer reads the update 
information from the second server (Column 8, lines 31 - 35). 

Regarding claim 40, Leblang discloses that the first server comprises a 
HyperText Transfer Protocol (HTTP) server (Column 8, lines 43 - 51 ). 

Regarding claim 41 , Leblang discloses that the HTTP server comprises a 
Dynamic Host Configuration Protocol (DHCP) server having Uniform Resource 
Identifiers (URIs) for querying the second server (Column 6, lines 1-19). 

Regarding claim 42, Leblang discloses that the HTTP server comprises a 
Domain Name System (DNS) server having a service (SRV) record for identifying the 
second server (Column 8, lines 43 - 51 ). 

Regarding claim 43, Leblang discloses that the HTTP server comprises a 
directory service for providing the location information for the update information to the 
computer (Column 6, lines 51 - 61 ). 

Regarding claim 44, Leblang disclose that the first server comprises an 
Application Configuration Access Protocol (ACAP) server (Column 12, lines 56 - 67). 

Regarding claim 45, Leblang discloses that the first server comprises a 
Lightweight Directory Access Protocol (LDAP) server (Column 8, lines 30 - 35; Column 
11, lines 61 -64). 



Application/Control Number: 09/670,073 
Art Unit: 2155 



Page 1 1 



Regarding claim 47, Leblang discloses a computerized system, comprising: a 
first server comprising location information for update information associated with an 
executable file (Column 5 t lines 45 - 53; Column 8, lines 31 - 35; Column 2, lines 53 - 
64; Column 1 1 , lines 53 - 60); a second server comprising the update information 
(Column 6, lines 4-10), wherein the first server is linked to the second server though a 
path that is created based on the type of update information without register the path 
with an environment variable (Column 2, line 67 - Column 3, line 4): and a computer 
comprising the executable file, wherein the first server is adapted to provide the 
computer with the location information (Column 2, line 67 - Column 3, line 4) , and 
further wherein the computer uses the location information to query the second server 
through the path for the update information (Column 8, lines 43 - 51 ) such that software 
associated with the executable file is updated based on the update information (Column 
2, lines 53 - 64; Column 1 1 , lines 53 - 60). 

Regarding claim 48, Leblang discloses the first server is selected from a group 
consisting of a DHCP server, a DNS server, an ACAP server, and a LDAP server 
(Column 3, lines 31 - 40; Column 2, line 65 - Column 3, line 1 ; Column 8, lines 43 - 51 ; 
Column 12, lines 56 - 67) where the type of connection and query and action the user 
takes, allows the system to take different action with the first server/ distributed system. 

Regarding claim 49, Leblang discloses that the computer is configured to query a 
hierarchy of first servers in a serial order (Column 2, lines 65 - Column 3, line 4; 
Column 16, lines 62 - 67) because in order to connect all the objects and locate all 
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related information to those objects the system needs to transverse all paths and types 
of location techniques in the system, such as first locating the object and the pathnames 
to that objects versions, then looking in the object directory for metadata leading to 
hyperlinks for other objects which are merged or related. 

Regarding claim 50, Leblang does not explicitly indicate that the computer is 
configured to query a hierarchy of first servers in a parallel order (Column 16, lines 6 - 
9) where the script allows the search of may objects/files at once and it also allows 
different types of searching for those files such as certain version location or query into 
the metadata. 

Regarding claim 51 , Leblang does not explicitly indicate that the update 
information comprises solution access information (Column 5, line 61 - Column 6, line 
5). 

Regarding claim 52, Leblang does not explicitly indicate that the computer is 
configured to query the second server, in an HTTP request format (Column 9, lines 47 - 
61) , for the update information using a qualifier associated with the executable file 
(Column 15, lines 46-51). 

Regarding claim 53, Leblang discloses that the query to the second server is 
performed using metadata extracted from the executable file (Column 2, lines 24 - 52). 

Regarding claim 54, Leblang discloses that the metadata extracted from the 
executable file comprising metadata for a debug file associated with the executable 
(Column 17, lines 2 -10) . 
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Regarding claim 55, Leblang does not explicitly indicate that the metadata 
extracted from the executable file comprises metadata associated with regression 
analysis data for the executable file (Column 5, line 61 - Column 6, line 3). 

Regarding claim 56, Leblang discloses that a computer readable medium having 
computer executable instructions to cause a computing system to perform a method for 
updating software associated with an executable file (Column 5, lines 45 - 53; Column 
8, lines 31 - 35; Column 2, lines 53 - 64; Column 1 1 , lines 53 - 60), comprising: 
creating a path for a lookup server to a server having update information associated 
with an executable file based on the type of update information without registering the 
path with an environment variable (Column 14, lines 25 - 39; Column 2, line 2) : using 
the lookup server to identify location information for the server having the update 
information based on metadata extracted from the executable file; packaging an HTTP 
query for retrieving the update information through the path (Column 2, line 67 - 
Column 3, line 4; Column 8, lines 31 - 35; Column 16, lines 31 - 44; lines 62 - 67); 
retrieving the update information; and updating the software associated with the 
executable file based on the update information (Column 2, lines 53 - 64; Column 1 1 , 
lines 53-60). 

Regarding claim 57, Leblang discloses that using the lookup server further 
comprises providing a response to a requesting client from the lookup server (Column 
1 6, lines 40-44; Column 1 7, lines 50 - 57). 
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Regarding claim 58, Leblang discloses that providing a response further 
comprises forwarding the location information to the requesting client as an HTTP 
redirect (Column 8, lines 31 - 35). 

Regarding claim 59, Leblang discloses a method for updating software 
associated with a local file comprising: packaging metadata extracted from the local file 
into an HTTP request to obtain information associated with the local file (Column 2, 
lines 24 - 52); sending the HTTP request to a locator server; receiving location 
information back from the locator server (Column 8, lines 31 - 35; Column 16, lines 40 - 
44; Column 17, lines 50 - 57); packaging an HTTP query for retrieving the information 
associated with the local file based on location information (Column 8, lines 43 - 51); 
and updating the software associated with the local file based on the information 
associated with the local file (Column 2, lines 53 - 64; Column 1 1 , lines 53 - 60). 

Regarding claim 60, Leblang does not explicitly indicate that packaging an HTTP 
query further comprises Qualifying the HTTP query to select a specific file version from 
the information associated with the local file (Column 8, lines 43 - 51). 

Regarding claim 61, Leblang does not explicitly indicate that qualifying the HTTP 
query further comprises qualifying the HTTP query to select an updated file version 
associated with the local file (Column 1 1 , lines 1 - 3) 

Regarding claim 62, Leblang does not explicitly indicate that qualifying the HTTP 
query further comprises qualifying the HTTP query to select a specific debug file 
associated with the local file (Column 17, lines 1 - 9). 
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Regarding claim 63, Leblang discloses a server architecture, comprising; a first 
server; a second server linked to the first server (Column 5, lines 45 - 53; Column 8, 
lines 31 - 35; Column 2, lines 53 - 64; Column 1 1 , lines 53 - 60) , wherein the second 
server comprises update information associated with the executable file (Column 6, 
lines 4-10); means for interpreting metadata associated with an executable file 
received bv the first server from a remote client (Column 16, lines 40 - 44); means for 
redirecting the remote client to the second server wherein the second server is adapted 
to interpret a query from the remote client for retrieving the update information (Column 
8, lines 31 - 35; lines 43 - 51 ); and means for updating software associated with the 
executable based on the update information (Column 2, lines 53 - 64; Column 1 1 , lines 
53 - 60), 

Claim Rejections - 35 USC § 103 

The following is a quotation of 35 U.S.C. 103(a) which forms the basis for all 
obviousness rejections set forth in this Office action: 

(a) A patent may not be obtained though the invention is not identically disclosed or described as set 
forth in section 102 of this title, if the differences between the subject matter sought to be patented and 
the prior art are such that the subject matter as a whole would have been obvious at the time the 
invention was made to a person having ordinary skill in the art to which said subject matter pertains. 
Patentability shall not be negatived by the manner in which the invention was made. 

Claim 46 is rejected under 35 U.S.C. 103(a) as being unpatentable over Leblang. 

Regarding claim 46, Shklar does not explicitly indicate that the computer is 
networked to the first and the second servers over the Internet. Shklar discloses that 
the system is a distributed network, with servers and workstations (Column 6, lines 4 - 
9) and that it uses pathnames to locate servers and information (Column 2, lines 65 - 
66). It would have been obvious to one of ordinary skill in the art at the time the 
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invention was made to encourage the scalability of the system to enable it to run over a 
wider area network such as the Internet to allow a larger more geographically disperse 
development team to operate cooperatively in this system (Column 6, lines 10 - 26). 

Response to Arguments 
Applicant's arguments with respect to claims 1-63 have been considered but are 
moot in view of the new ground(s) of rejection. 

Conclusion 

The prior art made of record and not relied upon is considered pertinent to 
applicant's disclosure. 

U. S. Patent No. 4714996 issued to Gladney, because it has a intercepter which 
finds a second location and looks for the requested information. 

U. S. Patent No. 6732358 issued to Siefert, because it uses a server to locate 
software updates at a separate location. 

U. S. Patent No. 6651249 issued to Waldin, because it uses a server to locate 
the software publisher and identify software updates. 

U. S. Patent No. 4558413 issued to Schmidt, because it involves searching for 
certain software versions and builds. 

Applicant's amendment necessitated the new ground(s) of rejection presented in 
this Office action. Accordingly, THIS ACTION IS MADE FINAL. See MPEP 
§ 706.07(a). Applicant is reminded of the extension of time policy as set forth in 37 
CFR 1.136(a). 
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A shortened statutory period for reply to this final action is set to expire THREE 
MONTHS from the mailing date of this action. In the event a first reply is filed within 
TWO MONTHS of the mailing date of this final action and the advisory action is not 
mailed until after the end of the THREE-MONTH shortened statutory period, then the 
shortened statutory period will expire on the date the advisory action is mailed, and any 
extension fee pursuant to 37 CFR 1 .1 36(a) will be calculated from the mailing date of 
the advisory action. In no event, however, will the statutory period for reply expire later 
than SIX MONTHS from the date of this final action. 

Any inquiry concerning this communication or earlier communications from the 
examiner should be directed to Kevin Bates whose telephone number is (703) 605- 
0633. The examiner can normally be reached on 8 am - 4:30 pm. 

If attempts to reach the examiner by telephone are unsuccessful, the examiner's 
supervisor, Hosain Alam can be reached on (703) 308-6662. The fax phone number for 
the organization where this application or proceeding is assigned is 703-872-9306. 

Information regarding the status of an application may be obtained from the 
Patent Application Information Retrieval (PAIR) system. Status information for 
published applications may be obtained from either Private PAIR or Public PAIR. 
Status information for unpublished applications is available through Private PAIR only. 
For more information about the PAIR system, see http://pair-direct.uspto.gov. Should 
you have questions on access to the Private PAIR system, contact the Electronic 
Business Center (EBC) at 866-217-9197 (toll-free). 
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